<!DOCTYPE html>
<html xmlns:wb="http://open.weibo.com/wb">
<head>
  <meta charset="utf-8">
  <script src="https://cdn.jsdelivr.net/gh/Sanarous/files@1.13/js/linkcard.js"></script>
  <script>
(function(){
    var bp = document.createElement('script');
    var curProtocol = window.location.protocol.split(':')[0];
    if (curProtocol === 'https') {
        bp.src = 'https://zz.bdstatic.com/linksubmit/push.js';
    }
    else {
        bp.src = 'http://push.zhanzhang.baidu.com/push.js';
    }
    var s = document.getElementsByTagName("script")[0];
    s.parentNode.insertBefore(bp, s);
})();
</script>
<script>
var _hmt = _hmt || [];
(function() {
  var hm = document.createElement("script");
  hm.src = "https://hm.baidu.com/hm.js?fc9a8559a133f4d8ce784d69d6337bb0";
  var s = document.getElementsByTagName("script")[0]; 
  s.parentNode.insertBefore(hm, s);
})();
</script>

  
  <title>论细节决定成败 | 涂宗勋的博客</title>
  <meta name="baidu-site-verification" content="o8pWlgAEZ7" />
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  <meta name="description" content="说明近期，工作中、工作外、个人、他人均遇到了不少问题，而这些问题的成因均因未注意细节而造成，使我再一次想起那句名言：细节决定成败。于是我觉得很有必要做一个记录，用以自警和他警。">
<meta property="og:type" content="article">
<meta property="og:title" content="论细节决定成败">
<meta property="og:url" content="https://tuzongxun.gitee.io/2017/11/14/wenti2/index.html">
<meta property="og:site_name" content="涂宗勋的博客">
<meta property="og:description" content="说明近期，工作中、工作外、个人、他人均遇到了不少问题，而这些问题的成因均因未注意细节而造成，使我再一次想起那句名言：细节决定成败。于是我觉得很有必要做一个记录，用以自警和他警。">
<meta property="og:locale" content="zh_CN">
<meta property="article:published_time" content="2017-11-14T00:55:07.000Z">
<meta property="article:modified_time" content="2019-08-13T07:38:09.143Z">
<meta property="article:author" content="涂宗勋">
<meta property="article:tag" content="修心•修性•修行">
<meta property="article:tag" content="思考总结">
<meta name="twitter:card" content="summary">
  
  
    <link rel="icon" href="/images/touxiang.png">
  
  
    
  
  
<link rel="stylesheet" href="/tzxblog/css/style.css">

  

<meta name="generator" content="Hexo 4.2.1"></head>

<body>
  <div id="container">
    <div id="wrap">
      <header id="header">
  <script src="https://tjs.sjs.sinajs.cn/open/api/js/wb.js" type="text/javascript" charset="utf-8"></script>
  <script src="https://cdn.jsdelivr.net/gh/Sanarous/files@1.13/js/linkcard.js"></script>
  <div id="banner"></div>
  <div id="header-outer" class="outer">
    
    <div id="header-inner" class="inner">
      <nav id="sub-nav">
        
        <a id="nav-search-btn" class="nav-icon" title="搜索"></a>
      </nav>
      <div id="search-form-wrap">
        <form action="//google.com/search" method="get" accept-charset="UTF-8" class="search-form"><input type="search" name="q" class="search-form-input" placeholder="Search"><button type="submit" class="search-form-submit">&#xF002;</button><input type="hidden" name="sitesearch" value="https://tuzongxun.gitee.io"></form>
      </div>
      <nav id="main-nav">
        <a id="main-nav-toggle" class="nav-icon"></a>
        
          <a class="main-nav-link" href="/tzxblog/">首页</a>
        
          <a class="main-nav-link" href="/tzxblog/shuoshuo/">说说</a>
        
          <a class="main-nav-link" href="/tzxblog/archives/">归档</a>
        
          <a class="main-nav-link" href="/tzxblog/collections/">导航</a>
        
          <a class="main-nav-link" href="/tzxblog/download/">资源</a>
        
          <a class="main-nav-link" href="/tzxblog/about/">简历</a>
        
      </nav>
      
    </div>
    <div id="header-title" class="inner">
      <h1 id="logo-wrap">
        <a href="/tzxblog/" id="logo">涂宗勋的博客</a>
      </h1>
      
        <h2 id="subtitle-wrap">
          <a href="/tzxblog/" id="subtitle">java程序员，现居武汉，CSDN博客https://blog.csdn.net/tuzongxun</a>&nbsp;&nbsp;&nbsp;&nbsp;
		  <!--<span id="busuanzi_container_site_pv">【本站累计访问量:<span id="busuanzi_value_site_pv"></span>】</span>-->
        </h2>
		
      
    </div>
  </div>
</header>
      <div class="outer">
        <section id="main"><article id="post-wenti2" class="article article-type-post" itemscope itemprop="blogPost">
  <div class="article-meta">
    <a href="/tzxblog/2017/11/14/wenti2/" class="article-date">
  <time datetime="2017-11-14T00:55:07.000Z" itemprop="datePublished">2017-11-14</time>
</a>
    
  <div class="article-category">
    <a class="article-category-link" href="/tzxblog/categories/%E4%BF%AE%E5%BF%83%E2%80%A2%E4%BF%AE%E6%80%A7%E2%80%A2%E4%BF%AE%E8%A1%8C/">修心•修性•修行</a>
  </div>

</span>
  </div>
  <div class="article-inner">
    
    
      <header class="article-header">
        
  
    <h1 class="article-title" itemprop="name">
      论细节决定成败
    </h1>
  

      </header>
    
    <div class="article-entry" itemprop="articleBody">
      
        <!-- Table of Contents -->
        
        <h3 id="说明"><a href="#说明" class="headerlink" title="说明"></a>说明</h3><p>近期，工作中、工作外、个人、他人均遇到了不少问题，而这些问题的成因均因未注意细节而造成，使我再一次想起那句名言：细节决定成败。于是我觉得很有必要做一个记录，用以自警和他警。</p>
<a id="more"></a>
<h3 id="事件一：一个数据库预留字段造成的上线失败"><a href="#事件一：一个数据库预留字段造成的上线失败" class="headerlink" title="事件一：一个数据库预留字段造成的上线失败"></a>事件一：一个数据库预留字段造成的上线失败</h3><p>这个事其实是比较严重的一个事，因为涉及到了生产，并严重影响甲方公司对我方的评价。<br>整个经过大概是这样：<br>甲方公司给我们公司提出了一个需求，这个需求是六月份开始建立工单的，而实际开发应该是五月份就已经开始。<br>这个任务不是我负责，因此我并不了解细节详情，只是听经理说并不是很难的一个任务，当然了，也可能只是他认为不难。<br>结果，这个任务直到十一月份才正式上线，持续了近半年。而持续了近半年才上线，结果还是以上线失败告终，目前又被打回重新开发。<br>这些其实不是最重要的，最重要的问题是上线失败的原因，是因为新开发的功能使用了原来数据库的三个预留字段之一。<br>也不清楚究竟是什么原因，导致上线后才发现那个预留字段已经有其他业务在使用了，导致最终上线失败。<br>仅仅是一个字段是否被使用的问题，未在上线前确认好，导致五个月的成果几乎功亏一篑，这件事直接造成甲方公司对我方的评价大打折扣，是为细节决定成败的事件1。</p>
<h3 id="事件二：一个空格耽误的半天时间"><a href="#事件二：一个空格耽误的半天时间" class="headerlink" title="事件二：一个空格耽误的半天时间"></a>事件二：一个空格耽误的半天时间</h3><p>这个问题其实不止遇到过一次，相信也不止我一个人遇到过，那就是开发过程中配置文件里的空格。<br>因为这次的项目开发要把sybase数据库改为oracle数据库，oracle又不是很好安装，所以一开始我是没有在本机安装oralce的，直接使用公司服务器的oracle开发。<br>代码基本开发完毕的时候，我抽空在自己电脑上安装了oracle，各种测试都没有问题后，正式使用代码连接我自己的数据库。<br>结果呢，运行过程中始终提示用户验证不通过。<br>我查了用户名和密码，怎么看都是对的，一开始以为还是数据库服务器哪里配置有问题，但是各种验证之后又最终确定数据库服务器是没有问题的。<br>如此头疼的花了半天时间后，我无言以对的发现，竟然是配置文件中用户名末尾多了个看不出来的空格，就是这个罪魁祸首，使我几乎抓狂，又做了若干的无用功，是为细节决定成败的事件2。</p>
<h3 id="事件三：一个博客中的细节遗漏导致自己差点怀疑自己"><a href="#事件三：一个博客中的细节遗漏导致自己差点怀疑自己" class="headerlink" title="事件三：一个博客中的细节遗漏导致自己差点怀疑自己"></a>事件三：一个博客中的细节遗漏导致自己差点怀疑自己</h3><p>一年多之前，我有写过activiti自定义流程的系列博客，如今我已经很久没有再用这个技术了，但是有很多用这个技术的同学还在参考我写的那些笔记。<br>但是最近有个同学遇到了一个问题，他按照我说的方法，甚至完全使用我的代码后，有个环节始终得不到正确结果。<br>当他问我的时候，我一开始抱着“我怎么会错”的、据说是标准程序员心态的心态，坚定的认为一定是他写的有问题。<br>然而，当我自己按自己的代码再来一遍时，竟然得到了和他一样的结果，那个环节也不正确。<br>后来我有别的事就暂停了找问题，而那个同学因为必须解决这问题，就一直找了下去。<br>最终还是他发现其实我写的没有问题，方法和代码都没有问题，问题在于画流程图的时候一些细节没有注意。<br>那些画流程图的细节我并没有在博客中说明，导致别人不知道这个细节，连我自己也都忘记，还以为自己写的有错误，是为细节决定成败的事件3。<br>具体那篇博客参考<a href="http://blog.csdn.net/tuzongxun/article/details/51154101" target="_blank" rel="noopener">http://blog.csdn.net/tuzongxun/article/details/51154101</a></p>
<h3 id="事件四：一个扫描路径定义耽误的几个人的几个小时"><a href="#事件四：一个扫描路径定义耽误的几个人的几个小时" class="headerlink" title="事件四：一个扫描路径定义耽误的几个人的几个小时"></a>事件四：一个扫描路径定义耽误的几个人的几个小时</h3><p>这次项目spring+struts2+mybatis重构为springboot+jpa，由于过往不规范的开发经验，导致写的代码问题很多，也不规范。<br>在确定整体业务流程正确之后，我们进行了一轮重构，主要是根据阿里新发布的java开发规范进行一些优化。<br>在这个优化过程中，我修改了一个数据库对应的实体类的包名，然后启动项目之后就无论如何也扫描不到那些实体类了。<br>然后我查看了springboot项目的目录结构，所有包都位于启动类同级或者同级的下级，按理说默认都会扫描到才对。<br>然后又查看了各个实体类的注解，该有的和jpa对应的注解也都不少。<br>然后又看了springboot的启动类，也都配置了包扫描路径，确定没有问题。<br>于是我实在找不到问题出在哪里，遂请教了两个对springboot更熟悉的同事，结果他们帮忙也找了很久，很久之后依然没有解决问题。<br>就这样，最终是另一个一起开发的同事找出了问题，原来是他写的某个切换数据源的方法中定义了实体类扫描路径，导致更换了包名之后的包名和他之前那个定义的字符串不匹配。<br>正常来说，这种字符串不应该是写在方法中的，不规范的细节，导致几个人几个小时的流失，并且最终发现都是无用功，是为细节决定成败事件4。</p>
<h3 id="事件五：一个包名写错导致的诡异问题"><a href="#事件五：一个包名写错导致的诡异问题" class="headerlink" title="事件五：一个包名写错导致的诡异问题"></a>事件五：一个包名写错导致的诡异问题</h3><p>这次的项目大重构，分为三个子模块，由于每个模块负责人不一样，又没有统一的具体规范要求，导致风格迥异。<br>其中一个同事创建的springboot项目就比较个性，首先是他的springboot项目看起来是maven创建，但是别人拿过来放入eclipse后，均需要先转成maven项目才能成为真正的maven项目。<br>其次就是在eclipse中正常运行，结果在打成jar包时，jar包里什么配置文件都没有，导致jar包无法以预期的结果运行。<br>后来找来公司的高手一番查找后，发现打包命令没有问题，各种配置也正常。<br>没把配置文件打进jar包的原因，是因为maven配置文件默认目录src/main/resources，他写成了src/main/resouces,单词resources中少了一个r。<br>这很显然是手动创建项目目录，导致手误，少写了字符，先不说这种方式如何，单单就事论事，一个字符缺失导致这样的诡异问题，是为细节决定成败事件5。</p>
<p><strong>以上事件，除开第一个之外，其他看起来似乎也都不算太大的事，但是这样的事频繁的发生，就不得不引起重视。</strong><br><strong>细节决定成败，态度决定人生，希望以此自警和他警！</strong></p>

      
    </div>
    <footer class="article-footer">
      <a data-url="https://tuzongxun.gitee.io/2017/11/14/wenti2/" data-id="ckxn7cxk50079kcvh67l61u4f" class="article-share-link">分享</a>
      
      
      
  <ul class="article-tag-list" itemprop="keywords"><li class="article-tag-list-item"><a class="article-tag-list-link" href="/tzxblog/tags/%E4%BF%AE%E5%BF%83%E2%80%A2%E4%BF%AE%E6%80%A7%E2%80%A2%E4%BF%AE%E8%A1%8C/" rel="tag">修心•修性•修行</a></li><li class="article-tag-list-item"><a class="article-tag-list-link" href="/tzxblog/tags/%E6%80%9D%E8%80%83%E6%80%BB%E7%BB%93/" rel="tag">思考总结</a></li></ul>

    </footer>
  </div>
  
    
  <div class="comments" id="comments">
    
     
       
       
      
      
	 
  </div>
 
    
 
<script src="/tzxblog/jquery/jquery.min.js"></script>

  <div id="random_posts">
    <h2>推荐文章</h2>
    <div class="random_posts_ul">
      <script>
          var random_count =5
          var site = {BASE_URI:'/tzxblog/'};
          function load_random_posts(obj) {
              var arr=site.posts;
              if (!obj) return;
              // var count = $(obj).attr('data-count') || 6;
              for (var i, tmp, n = arr.length; n; i = Math.floor(Math.random() * n), tmp = arr[--n], arr[n] = arr[i], arr[i] = tmp);
              arr = arr.slice(0, random_count);
              var html = '<ul>';
            
              for(var j=0;j<arr.length;j++){
                var item=arr[j];
                html += '<li><strong>' + 
                item.date + ':&nbsp;&nbsp;<a href="' + (site.BASE_URI+item.uri) + '">' + 
                (item.title || item.uri) + '</a></strong>';
                if(item.excerpt){
                  html +='<div class="post-excerpt">'+item.excerpt+'</div>';
                }
                html +='</li>';
                
              }
              $(obj).html(html + '</ul>');
          }
          $('.random_posts_ul').each(function () {
              var c = this;
              if (!site.posts || !site.posts.length){
                  $.getJSON(site.BASE_URI + 'js/posts.js',function(json){site.posts = json;load_random_posts(c)});
              } 
               else{
                load_random_posts(c);
              }
          });
      </script>
    </div>
  </div>

	
<nav id="article-nav">
  
    <a href="/tzxblog/2017/11/14/maven6/" id="article-nav-newer" class="article-nav-link-wrap">
      <strong class="article-nav-caption">上一篇</strong>
      <div class="article-nav-title">
        
          《maven实战》学习笔记6——maven聚合和继承
        
      </div>
    </a>
  
  
    <a href="/tzxblog/2017/11/13/maven5/" id="article-nav-older" class="article-nav-link-wrap">
      <strong class="article-nav-caption">下一篇</strong>
      <div class="article-nav-title">《maven实战》学习笔记5——maven仓库和镜像</div>
    </a>
  
</nav>

  
</article>

</section>
           
    <aside id="sidebar">
  
    <!--微信公众号二维码-->


  
    

  
    
  
    
    <div class="widget-wrap">
    
      <div class="widget" id="toc-widget-fixed">
      
        <strong class="toc-title">文章目录</strong>
        <div class="toc-widget-list">
              <ol class="toc"><li class="toc-item toc-level-3"><a class="toc-link" href="#说明"><span class="toc-number">1.</span> <span class="toc-text">说明</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#事件一：一个数据库预留字段造成的上线失败"><span class="toc-number">2.</span> <span class="toc-text">事件一：一个数据库预留字段造成的上线失败</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#事件二：一个空格耽误的半天时间"><span class="toc-number">3.</span> <span class="toc-text">事件二：一个空格耽误的半天时间</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#事件三：一个博客中的细节遗漏导致自己差点怀疑自己"><span class="toc-number">4.</span> <span class="toc-text">事件三：一个博客中的细节遗漏导致自己差点怀疑自己</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#事件四：一个扫描路径定义耽误的几个人的几个小时"><span class="toc-number">5.</span> <span class="toc-text">事件四：一个扫描路径定义耽误的几个人的几个小时</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#事件五：一个包名写错导致的诡异问题"><span class="toc-number">6.</span> <span class="toc-text">事件五：一个包名写错导致的诡异问题</span></a></li></ol>
          </div>
      </div>
    </div>

  
    

  
    
  
    
  
    

  
</aside>

      </div>
      <footer id="footer">
  <script async src="//busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js"></script>
  
  <div class="outer">
    <div id="footer-left">
      &copy; 2016 - 2021 涂宗勋&nbsp; <a href="https://beian.miit.gov.cn/#/Integrated/recordQuery" target="_blank" rel="noopener">鄂ICP备20000142号</a> |&nbsp;&nbsp;
      主题 <a href="https://github.com/giscafer/hexo-theme-cafe/" target="_blank">Cafe</a>&nbsp;|&nbsp;&nbsp;
	  <span id="busuanzi_container_site_uv">本站有效访客数<span id="busuanzi_value_site_uv"></span>人</span>
	  <span id="busuanzi_container_site_pv" >| 总访问量 <span id="busuanzi_value_site_pv"></span> 次 </span>
	  <div style="width:300px;margin:0 auto; padding:20px 0;"><a target="_blank" href="http://www.beian.gov.cn/portal/registerSystemInfo?recordcode=42010302002171"style="display:inline-block;text-decoration:none;height:20px;line-height:20px;"><img src="http://www.tzxcode.cn/wp-content/uploads/2020/01/备案图标.png" style="float:left;"/><p style="float:left;height:20px;line-height:20px;margin: 0px 0px 0px 5px; color:#939393;">鄂公网安备 42010302002171号</p></a>
		 	</div>
    </div>
     <div id="footer-right">
      联系方式&nbsp;|&nbsp;1160569243@qq.com
    </div>
	
  </div>
</footer>
 
<script src="/tzxblog/jquery/jquery.min.js"></script>

 <script>
$(document).ready(function() {

    var int = setInterval(fixCount, 50);  // 50ms周期检测函数
    var countOffset = 20000;  // 初始化首次数据

    function fixCount() {            
       if (document.getElementById("busuanzi_container_site_pv").style.display != "none")
        {
            $("#busuanzi_value_site_pv").html(parseInt($("#busuanzi_value_site_pv").html()) + countOffset); 
            clearInterval(int);
        }                  
        if ($("#busuanzi_container_site_pv").css("display") != "none")
        {
            $("#busuanzi_value_site_uv").html(parseInt($("#busuanzi_value_site_uv").html()) + countOffset); // 加上初始数据 
            clearInterval(int); // 停止检测
        }  
    }
       	
});
</script> 
    </div>
    <nav id="mobile-nav">
  
    <a href="/tzxblog/" class="mobile-nav-link">首页</a>
  
    <a href="/tzxblog/shuoshuo/" class="mobile-nav-link">说说</a>
  
    <a href="/tzxblog/archives/" class="mobile-nav-link">归档</a>
  
    <a href="/tzxblog/collections/" class="mobile-nav-link">导航</a>
  
    <a href="/tzxblog/download/" class="mobile-nav-link">资源</a>
  
    <a href="/tzxblog/about/" class="mobile-nav-link">简历</a>
  
</nav>
    <img class="back-to-top-btn" src="/images/fly-to-top.png"/>
<script>
// Elevator script included on the page, already.
window.onload = function() {
  var elevator = new Elevator({
    selector:'.back-to-top-btn',
    element: document.querySelector('.back-to-top-btn'),
    duration: 1000 // milliseconds
  });
}
</script>
      

  

  







<!-- author:forvoid begin -->
<!-- author:forvoid begin -->

<!-- author:forvoid end -->

<!-- author:forvoid end -->



 
<script src="/tzxblog/js/is.js"></script>



  
<link rel="stylesheet" href="/tzxblog/fancybox/jquery.fancybox.css">

  
<script src="/tzxblog/fancybox/jquery.fancybox.pack.js"></script>




<script src="/tzxblog/js/script.js"></script>


<script src="/tzxblog/js/elevator.js"></script>

  </div>
</body>
</html>